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Mysql 


q lingua MySQL 


Uma abordagem teórica-prática sobre a Linçuasem 
de banco de dados mais usada no mundo 


por Michael Granados 


rganizar e agrupar parecem ser tendências naturais 

do ser humano. Sempre procuramos manter a ordem 

e o equilíbrio sobre todas as coisas ao nosso redor. 

Essa técnica é utilizada em quase todos os lugares por 

onde passamos. Olhe em sua volta: mesmo que não 
queira você acaba de agrupar alguns elementos por cor, forma 
ou tamanho. Assim como os objetos físicos, as informações 
também podem ser agrupadas. Uma dona de casa procura em 
seu caderno o prato que mais possa agradar seus convidados. 
O caderno é um banco cheio de informações úteis. Esse é um 
belo exemplo de banco de dados, uma vez que informações são 
conhecidas como dados, em informática. 

Contudo, as informações (principalmente em grande escala) 
não têm valor, se não houver alguma maneira de interagir com os 
dados adicionando novos registros, contando quantos registros de 
determinado valor existem, definindo classificação, como ordem 
alfabética ou filtrando dados por um critério. Essas funcionalida- 
des, que nos ajudam bastante no dia-a-dia, ficam a cargo dos 
sistemas de bancos de dados. 

Claro que não existe apenas um tipo de sistema de banco de 
dados, diversas empresas produzem inúmeros bancos de dados 
e disponibilizam, vendem ou mesmo alugam os sistemas. Os 
sistemas, em sua maioria, trabalham com uma linguagem em 
comum: SQL. Essa linguagem é a mais usada por ser simples e 
de fácil aprendizado. Além disso, os comandos dela são muito 
humanizados, o que a torna tão popular. Mesmo quem não en- 
tende nada de informática pode compreender facilmente certos 
comandos, como “SELECT * FROM vendas” ou, em português, 
“selecione tudo das vendas”. 

Um dos bancos de dados mais usados no mundo é o MyS- 
QL, que ganhou força por meio da Internet por se integrar a 
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várias linguagens de programação, como ASP, PHP, Perl ou 
Python. O MySQL também se comporta extremamente bem 
quando o assunto é portabilidade. Ele funciona na maioria dos 
sistemas operacionais, como Linux, Windows, Maco0Os, entre 
outros. Também adquiriu preferência por ser um sistema livre 
para desenvolvedores. 

Geralmente, o MySQL é usado para sistemas na Internet em 
conjunto com a linguagem de programação PHP no servidor 
Apache rodando na plataforma Linux. Esse time de ferra- 
mentas é conhecido como LAMP (Linux + Apache + MySQL 
+ PHP). Sistemas de grande porte foram construídos com o 
LAMP, por exemplo, a Wikipédia. Mas isso não impede que o 
MySQL funcione em desktop também com o Delphi ou o VB 
por exemplo, além de rodar perfeitamente sem o auxílio de 
qualquer interpretador. 

Neste tutorial, você vai aprender a instalar, configurar e dar 
seus primeiros passos com o MySQL, criar um banco de dados, 
uma tabela e inserir e selecionar dados da mesma. Após ler a 
revista, você perceberá que não há motivo para depender de 
programas que fazem tudo para facilitar e deixam código sujo 
com inúmeras funções que talvez não sejam úteis, porque você 
só precisa de ações simples. Aprendendo a linguagem do MySQL 
naturalmente, você também aprende muitas funcionalidades de 
outros bancos de dados como o Postgree ou SQLite, já que todas 
essas linguagens se baseiam no padrão SQL. Então, arregace as 
mangas e mãos à obra! 
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1 — vá até o site do MySQL (www.mysqgl.com) para efetuar o 
download do sistema de banco de dados que será instalado 
no servidor. 


Windows downloads (piztiom notes) 


Windows Essentiais (86) sos  229M Rca 
mis tetacarantosesatanirenapestobse 


Windows ZIP/Setup.EXE (x85) 5045 424M Pick a mirror 
OJePIaGSECSATOS ( Signature 
without instaler (unzip im C:) 


Windows x64 downloads (pistiorm notes) 
Windows Essentials (AMDGS / Intel EMSST) 


Windows ZIP/Setup.EXE (AMDSS / Intel EMSST) 


Without instalar (AMDÉS / Intel EM6ST) 
vos SetasErtassatitm tato e reettetetta | Ergrutuco 
Linux (non RPM packages) downloads (pistiorm notes) 


Linux (x86, gibc-2.2, “standard” is static) SOM 75.6M 
VWES) JchTISSIS cc TERToLEsSDaRILESNE | segratre 


Pick a mivror 
Unux (x86) 

Linux (AMD6S / Intel EMG4T) 

Linux (1h64, Red Hat AS 2.1, static) 


Unux (POWER / PowerPC, 32-bit) 


3 — Para Windows, existem três versões: apenas o essencial, 
completa ou sem instalador, para que você possa fazer a instalação 
na unha. Este tutorial utiliza a primeira versão. 


T 
iz MySQL Server 5.0 - Setup Wizard 


Wizard Completed 
Setup has finished instaling MySQL Server 5.0. Click Finish to 


[9 configure the MySQL Server now 
lips fis apidon da generate em arinizod MSC cando 
file, setup a Windoves service running on a dedicated port 


and to set the password for the root account. 


5 — Ao final da instalação, o sistema vai perguntar se você 
deseja configurar o banco de dados. Deixe essa caixa marcada 
e conclua a instalação. 


* MySQL 5.0 Community Server - Generally Available (GA) Release 
in contrast to the MySQL Enterpnse Server, which receives both monthiy rapid updates and quarterly service pack releases, there is no 
Server wil also be available in the 
+ Downloads Section, the binaries listed on this page may be from a previous release. in any case, full binaries for all our supported 
operating systems are and will remam convenientiy avadable from this page. 
= The Standard binaries are recommended for most users 
+ The Debug banaries have been compded with extra debug information, and are not intended for production use, because the 
included debugging code may reduce performance. 
* vem the MySQL 5.0 List of Changes 
We suggest that you usa the MDS checksums and GruPG signatures to verify the integnty cf the packages you download. 


* E-mails 


"GRATIS: 


* Note: It is good practice to back up your data bofora instalhng any nev version of software. Although MySQL has done its best 
to ensure à high level of quality, you should protect your data by making à backup, MySQL generally recommends that you dump 
and reload your tablas from any previcus version to upgrade to 5.0. 


Pe windobhdxos 

* Linux (non REM packages) 

» Linux (non RPM, Intef C/C++ compled, giibe-2.3) 

« Red Hat Enterprise Linux 3 REM fx85) 

* Red Hat Enterprise Linerr 3 FPM (AMDGS / Intel EM6ST) 
Red Mat Enterprise Linti 3 RPM (Intel 164) 

» Red Hat Enterprise Linux 4 FPM bx86) 

» Red Hat Enterprisa Lineu 4 RPM (AMDGS / Intel EMGAT) 

» Red Mat Enterprise Lima à REM (Intel tA54) 

« Red Hat Enterpriza Limux 5 REM fxa6) 

+ Red Hat Entecprisa Lina 5 RPM (AMDGS / Intel EMGAT) 


2 — Na área de download, escolha seu sistema operacional para 
que o banco de dados se adapte perfeitamente ao local em que 
será instalado. 


Setup Type 
Choose the setup type that best suits your needs. 


4 - Inicie a instalação normalmente e use as configurações-pa- 
drão. A instalação do MySQL era complicada e sua configuração 
costumava ser feita no bloco de notas. Agora, tudo é mais fácil. 


ver Instance Configuration Wizard 


Welcome to the MySQL Server Instance 
Configuration Wizard 1.0.8 


The Configuration Wizard wil allow you to configure the 
MySQL Server 5.0 server instance. To Continue, click 
Next, 


6 — Automaticamente, o instalador lançará o configurador do 
MySQL. Veja, na imagem, a tela que você deve visualizar a esta 
altura da atividade. 


GeEK ESPECIAL 5 


MySQL Server Instance Configuration Wizard 
MySQL Server Instance Configuration 
Configure the MySQL Server 5,0 server Instance, 
Please set the Windows options. 
Install As Windows Service 
pa This Is the recommended way to run the MySQL server 
IP) on Windows, 


Service Name: AySQU 4] 


[V] Launch the MySQL Server automatically 


[Include Bin Directory in Windows PATH 


Check this option to indude the directory containing the 
Ta server / dient executables In the Windows PATH variable 
so they can be called from the command line. 


7 — Nesta tela, você configura seu sistema operacional para 
utilizar o MySQL como serviço, deixando como opção que ele se 
inicie junto ao Windows. 


MySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration 
Configure the MySQL Server 5.0 server instance. 


Processing configuration ... 


(Z Prepare configuration 
(4% write configuration file (ClArquivos da programas|MySQUIMYSQL Server 5.0ymyii 


(Wj Start service 
( Apply security settings 


9 — Ao final, o programa demonstra seu relatório de processos: 
preparar a configuração; escrever o arquivo de configuração; ini- 
ciar o serviço e aplicando as configurações do banco de dados. 


ommand Line Client 


11 — primeira coisa que você deve fazer para começar a brin- 
car com o banco de dados é entrar com a senha do root. Lembra 
daquela senha alguns passos atrás? 
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MySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration 
Configure the MySQL Server 5,0 server instance, 


E Please set the gearity, piora. 
[2] Modify Security Settings 
New root password: 
Confirm: 
Enable root access from remote machines 


[El create An Anonymous Account 


This option wil create an anonymous account on this server, Please 
note that this can lead to an insecure system, 


8 — Defina uma senha para que o usuário root possa utilizar o 
banco de dados. Em sistemas de informática, root é o usuário prin- 
cipal que tem o controle sobre tudo o que ocorre no sistema. 


Windows XP Professional 


Pesquisar 


Ajuda e suporte 


Fazer logoff de michael... 


Desligar o computador... 


Iniciar 


10 - inicie o prompt de comando do MySQL. Perceba que, se você 
quiser configurar seu banco de dados novamente, poderá fazer isso 
com a ferramenta de configuração contida neste mesmo menu. 


12 - Depois de fazer o login, use o comando SHOW DATABASES 
para ver quais bancos de dados é possível utilizar para fazer 
novos projetos. 


MySOL Command Line Client 


2 06000 
» MySQL monitor. Commands end uvith ; or Ng. 
+ connection id is 2 
»sion: 5.8.45-community-nt MySQL Community Edition (GPL) 
'nh' for help. Type '=c* to clear the buffer. 
mysql> show databases; 
+ 
1 Database 
' + 
information schema + 
1 mysql 
| test 
+ + 
) rous in set (8.03 sec) 
mnysql> create datahase michael; 
Query OK, 1 row affected (CB.02 sec) 


mysql> use michael; 
Datahase changed 
nysql> 


13 — com os comandos CREATE DATABASE <NOME DO BANCO> 
e USE <NOME DO BANCO», respectivamente, crie um novo banco 
e passe a usá-lo como referência para os outros passos. 


le pessoa 
nome varcharc50), 
idade int 


y OK, 8 rous affected CB.08 sec) 
how tables; 


s. in michael 1 


et <B.08 


insert into ne , 


pessoas (no 
y OK, 1 row affected <B.85 


mysql> insert into pessoas value 
Query OK, 1 row affected (0.03 sec) 
nysql> inser nto pesso “, 43); 
ERROR 1366 <HYBB0): Incorrect column “idade! at row 1 
mysql> insert into pessoa 5 

Query OK, 1 row affected « 


mysql> insert into pe 


la", 


Query OK, 3 
Rec 


ords: 


mysql 


15 - Insira dados nesse banco. Veja que ocorreu um erro ao 
tentarmos alocar um texto no campo de valor inteiro. Logo, a 
escolha do tipo de dado é importante. 


| Gabriel 

i Nathália | 

+ + + 

6 rowus in set (8.06 sec) 


mysql> select * from pessoas where idade > 28; 
4—— + + 


1 nome idade 1 


Jim MA 
s in set (B.0B sec) 

mysql> update pessoas set idade 40 where nome “Paula”; 

Query OK, 1 row affected (0.03 sec) 

Rows matched: 1 Changed: 1 MWarnings: B 


mysql> select * from pessoas where nome = "Paula"; 
+ + + 

1 nome | idade 1 

+ + 


i Paula | 
4>——>—>>>4———————+ 


1 row in set (B.8B sec) 


17 — Para atualizar alguma informação, use o comando UPDATE, 
configurando valores com a diretiva SET. Especifique onde aconte- 
cerá essa atualização no banco de dados com o filtro WHERE. 
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Type “help;” or sh” for help. Type 'Nc! to clear the buffer. 


nysql> show databases; 
| Database 


information schema | 


set €8.03 sec) 


> create database michael; 
OK, 1 rou affected CA.02 se 


e michael; 
e changed 


| row in set (CB,00 sec) 


mysql 


14 — com o CREATE TABLE, crie uma tabela de pessoas com 
suporte a dois fatores: nome e idade. Veja que para cada tipo de 
informação, utiliza-se um atributo. 


CITE? TIM 
srt into pe le, nome 
» 1 row affected (0.03 sec> 


ssoas value 


> <“Nathália!, 20); 

Query OK, 3 vous affected (8.83 sec) 
Records: 3 Duplicates: 8 Marnings: Q 
nysql> select »* from pessoas; 


| 
! nome | idade | 


| Gabrie 
| Nathália 1 
6 vrows in set CB.08 sec) 


nysql> select * from pessoas where idade > 28; 


+ nome 1 idade 1 


+ Lui ' 
| Paula | 


2 rouws 


mysql) 


16 — selecione as pessoas com o comando SELECT para saber 
quais delas existem na tabela. Na sequência, foi usado um filtro 
chamado WHERE, para verificar as pessoas acima de 28 anos. 


mysql> update pessoas set idade = 48 where nome = "Paula"; 
Query OK, 1 row affected CB.83 sec) 
Rowus matched: 1 Changed: 1 Warnings: 8 


mysql> select * from pessoas where nome = "Paula"; 
4——————— + -———— + 
1 idade 1 
+—————— — + 


f row in set (8.088 sec) 


mysql> delete from pessoas where idade < 25; 
Query OK, 2 rous affected CB.03 sec) 


mysql> select * from pessoas; 
4————. -————— + 
nome idade 
Michael 
Alice 
Luis 
Paula 
e 
4 rows in 


' 
' 
+ 
1 
' 
1 
, 
1 
1 
1 
' 
+ 


mysql> 


18 — Para excluir dados, utilize o comando DELETE em conjunto 
com o filtro WHERE e o UPDATE. Para apagar tudo, use os comando 
“DROP TABLE pessoas” e “DROP DATABASE michael”. 
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NA PRÁCICA 


LUrta Sua 
pipoca com MySQL 


Aprenda alguns truques e conceitos da Linguagem 
SQL aplicada ao MySQL e monte sua locadora 


magine a seguinte situação: você entra em uma locadora, escolhe 

seu filme e pede à balconista. Ela pergunta seu código, mas você 

não se lembra. A garota procura seu cadastro por meio de uma 

parte do seu nome, ou outro dado que você tenha informado em 

sua ficha. Então, ela insere a locação no sistema com registro de 
data para controlar quantos dias você ficará com o filme. O sistema 
dessa locadora não é difícil de se reproduzir, desde que eles saibam 
utilizar seu banco de dados. 

Os recursos citados no parágrafo acima estão neste tutorial, que 
ensina, de forma prática, como aproveitar bem o MySQL. O sistema 
possuirá três tabelas básicas: clientes, filmes e aluguéis. Em aluguéis 
existe apenas a referência aos dados das outras duas tabelas, mas o 
banco retornará todas as informações juntas, automaticamente. 

Ao contrário do que muitos acreditam, o banco de dados não é so- 
mente uma ferramenta de armazenamento de informações, mas pode, 
também, manipular e retornar as informações pré-configuradas. O 
programador, geralmente, aprofunda-se na linguagem que acha mais 
interessante, como PHP, ASP ou Java, e termina por não perceber 
que, cedo ou tarde, terá de colocar as informações em um banco de 
dados. Não para fazer um backup de todas as matérias do site, mas 
para dar praticidade aos sistemas. O que ele não sabe é que, por 
não conhecer bastante a linguagem, ele pode perder funcionalidades 
importantes do próprio banco. 

E se fosse possível que o banco de dados retornasse quaisquer 
números que você gravasse como decimais? E se, para isso, não fosse 
necessária nenhuma programação extra? E se pudéssemos relacionar 
uma ou mais tabelas e o banco de dados as retornasse já mescladas 
com os valores referentes? Conhecendo um pouco mais a linguagem 
SQL, a programação não precisa ficar reinventando a roda. 

Comece aprendendo os tipos de dados que o banco suporta. Se 
quiser guardar um número, escolha, preferencialmente, o tipo inteiro. 
Mas se esse número precisa de casas decimais, como um valor mo- 
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netário, use o tipo de dado float que guarda os números com quantas 
casas decimais você preferir. Contudo, se esse valor for referente a 
um telefone ou CEP, na verdade, ele não é um numero, mas um en- 
dereçamento, e deve ser tratado como tal, ou seja, pertence ao tipo 
varchar. Portanto, um número só é um número quando você puder 
fazer cálculos matemáticos sobre ele. 

Listas, também conhecidas como ENUM, não guardam diversos va- 
lores ao mesmo tempo, elas têm um grupo de palavras ou expressões 
que são aceitas pelo banco. Se tentar inserir um número diferente, 
ele cancelará a inclusão do registro. 

Data e hora são um problema para qualquer programador: ter 
que dividir os pedaços de uma data ou hora e analisar cada um em 
separado (dia, mês, ano), repartindo até chegar ao valor em segun- 
dos e diminuir um do outro para, então, reconverter e descobrir qual 
a diferença entre os dois períodos de tempo. O MySQL consegue 
fazer esses cálculos e retornar diferenças entre datas que já estão 
no banco de dados. 

O próximo passo é aprender a mesclar as tabelas sem que seja 
necessário chamar uma tabela e a cada linha fazer um novo pedido 
ao banco de dados referente à outra tabela. Este recurso se chama 
JOIN e poupa os profissionais de programação. 
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MySQL Command Line Client 


* MySQL Command Line Client 
SQL monitor 


Commands end with ; 
connect ion id is 1 


5.0.45-community-nt MySQL 


er password: KXXHHX 
Ng. MySQL 


monitor, end with ; or 
“id is 16 


e 3. 09.45-community-nt MySQL Communit 
"c' to clear the buffer. 


Commands 9. 
Community Edition (GPL) 
"help;" or 'Nh' for help. Type " 


:"* or "Nh' for help. Type ' 
CREATE DATABASE locadora mysal> CREATE DATABASE locadora; 
1 row affected (0.00 e) Query 
mysal> USE locadora; 


y OK, 1 row affected (8.00 
Database changed 
mysql> 


y Edition ( 
nc" to clear the buffer 


sec) 


nged 
EATE TABLE clientes ( 
codigo int primary key auto increment, 
nome varchar(50), 
idade int, E 
endereco varchar( 100) 
Query OK, O rows affected (0.06 sec) 
mysaql> 


1- Começamos o sistema criando o banco de dados “locadora” 2 — Crie a tabela de clientes. Repare nos tipos de dados: código é 
por meio do comando CREATE DATABASE. Logo depois, passe a | inteiro, nome é pedaço de texto (varchar), idade é inteiro e endereço 
utilizar esse banco com o comando USE. outro varchar maior. Primary key indica o campo-chave. 


MySQL Command Line Client 


monitor. « 
3 connection id 
version: 5.0,45- 


ommands end with ; or *g. 
is 16 a 
community-nt MySQL Community Edition (GPL) 


o clear 


help;' or 'Nh" for help. Type 'Nc'! t the buffer. 
b piso DATABASE locadora; 

) 1 row affected (0.00 sec) 

sore aafe 


E] d 
CREATE “TA Fls cli entes ( 


€ 
ende reco varchar( 100) 


OK, OQ rows 


> INSERT INT 
) ("Alice 


affected (0.06 sec) 


TO c lientes (nome, 
EScarA 


Duplicates: 


3 Então, inserimos alguns clientes em nosso banco de dados 4 — Ao selecionarmos a tabela, note que o código inseriu valores 
Note que a idade é o único valor que não precisa de aspas. Ob- ii 


incrementados automaticamente. Isso se deve ao fato de o campo 
serve, também, que o campo código não foi colocado. possuir auto increment em sua criação. 


MySQL Command Line Client 


to increment, 


comedia", 


5 — Define-se a ordem na qual o sistema retornará os valores por 
meio da propriedade ORDER BY [COLUNA]. Você pode usar ASC para teo primary key auto increment, um varchar e uma lista ENUM com 
crescente e DESC para decrescente. ASC é a configuração-padrão. algumas definições e a sinopse do tipo TEXT, para textos longos 


6 —Criemos, então, a segunda tabela: filmes, em que temos novamen- 
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8- No passo anterior, um erro ocorre. Dessa forma, inserimos 
alguns filmes. Repare que, novamente, não nos importamos 
com o código, já que ele é gerado de modo automático. 


7 — veja o que acontece quando tentamos inserir um campo diferente 
dos valores indicados em ENUM. A palavra “desenho” não foi definida 


como parte de classificação. 


10 — ainda sobre a figura anterior, Valor é do tipo float com até 
cinco dígitos e mais dois decimais. Inicie a instalação. A essa altura, 
sua configuração deveria ser feita no bloco de notas. 


9 —Crie as tabelas relacionais. Tanto cliente como filme são do mesmo 
tipo dos campos codigo e cod, respectivamente. DataAluguel será do 


tipo DATE. 


MySQL Command Line Client 
ysql ERT INTO alugueis 


12 — Insira um campo em aluguéis para seguir adiante. O campo date 
segue o formato americano. Valor foi definido para funcinar com ponto 
antes dos decimais e com apenas uma casa decimal. 


11 — se você quiser resolver esse problema de forma simples e 
eficiente, selecione apenas os campos que deseja visualizar logo 
após a expressão SELECT. 
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ow in set (0.00 s 


14 — Sobre a figura do passo 13, a primeira comparação requer 
que a mesclagem seja feita onde o código de cliente for igual ao cliente 
de aluguéis. Na sequência, um join com as três tabelas. 


13 — Fazer um join é muito simples, utilize a seguinte sintaxe: JOIN 
[TABELA] ON [COMPARAÇÃO ENTRE AS TABELAS]. Os camos mostrados 
são definidos pela sintaxe [TABELAJ.[COLUNA]. 


MySQL Command Line Cliont 


16 — Por fim, o join das três tabelas. Veja a facilidade em se 
trabalhar com campos de dados relacionais, o que traz grandes 


benefícios ao seu projeto. 


15 — observe que a tabela em si não trabalha com nenhum 
texto, apenas faz referências às outras tabelas. Vamos seguir 


com as demais tabelas. 


- MySQL Command Line Client 


MySQL Command Line Client 


et (0.00 sec) 


SUM(valor) FROM alugueis GROUP BY cliente; 


mysgl> 


18 - Agora, com a propriedade GROUP BY [CAMPO], saberemos 
quanto cada cliente deve pagar. Note que somente a tabela alu- 
guéis foi selecionada. 


17 — se quisermos selecionar a soma dos valores da tabela 
aluguéis, use SUM(CAMPO). Esse tipo de dado pode ser obtido 
a qualquer momento. 
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-- MySQL Command Line Client 


3 rows in set (0.00 sec) 
ysql> SELECT clientes.nome, SUM(valor) FROM alugueis 


-> JOIN clientes ON clientes.codigo = alugueis.cliente 
-> GROUP BY cliente; 


in set (0.00 sec) 


19 -— Agora, inserimos o JOIN em meio ao exemplo anterior. 
Essa tarefa vai testar mais funcionalidades do banco de dados 
relacional que está sendo criado. 


MySQL Command Line Client 
O nO 


Imysaql> SELECT MAX(valor) FROM alugueis; 


1 row in set (0.00 sec) 


mysql> =. 


21 — Qual é o preço mais alto cobrado na locadora? Use 
MAX(CAMPO) para ter esse resultado. Outra tarefa muito sim- 
ples de ser realizada. 


MySQL Command Line Client 


mysql> SELECT codigo, nome FROM clientes; 


Eu 


Alice Castillo 
Raf ae amana 
Elizabete Andrade 
Paula Isabel 
(0.00 sec) 


+ 
4 rows in set 


mysql> 


23 — 0 usuário não sabe o próprio codigo, mas não é nada prático 
procurá-lo dentro de um banco de dados extenso como o de uma 
locadora em situação real, com mais de 500 clientes. 
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+ 
1 row in set (0.00 sec) 


mysql> SELECT COUNT(*) FROM filmes; 
+ 


+ 


+ 
1 row in set (0.00 sec) 


+ 
1 row in set (0.00 sec) 


mysgl> 


20 — Quantos filmes, clientes e locações a locadora possui? 
Com um simples COUNT(*) resolvemos o problema de modo 
muito simples. 


MySQL Command Line Client 


mysql> SELECT MAXx(valor) FROM alugueis; 
+ 


(2.00 sec) 


22 — O mesmo acontece quando usamos o argumento 
MIN(CAMPO) para valor mínimo. É um excelente modo de obter 
dados importantes para a locadora. 


-" MySQL Command Line Client 


ysql> SELECT codigo, nome FROM clientes; 
+ 


Alice Castillo 
Rafael Zamana I 
| Elizabete Andrade 
| Paula Isabel | 
rows in set (0.00 sec) 


ysql> SELECT codigo, nome FROM clientes WHERE nome LIKE "ax"; 
+ + 


set (0,00 sec) 


24 — Então, fazemos uma busca com o comando LIKE. Ele aceita 
determinados caracteres especiais, como %, que indica que qualquer 
espécie de texto pode estar no lugar. 


, titulo FROM filmes WHERE titul 
+ 


25-— Faça o mesmo para filmes, agora, ache algum que termine com 
“de”. Você pode buscar %andrade% para procurar alguém que tenha 
Andrade em um de seus sobrenomes, por exemplo. 


HiySOL Command Line Client 


27 — Ao utilizar a função CONTAT(VALOR1, VALOR2, VALOR3, VALORN) 
é possível juntar um texto a outro, e se tal texto for um número, ele 
será convertido para texto. 


-" MySOL Command Line Client 


29 — Ao alterar a data do meu sistema, o banco de dados 
receberá a nova data, logo, a função NOW() retorna uma nova 
data, como visto na imagem. 


26 — Insira um novo filme para o cliente encontrado. Em vez de es- 
crever a data na qual o filme foi alugado, foi usada a referência NOWO, 
que indica que o tempo a ser inserido é o da data atual. 


28 — Agora, a versão final com o preço já convertido para reais e 
mesclado com as outras tabelas. Fica a seu critério colocar um filtro 
ou outros campos, como aluguel, que indiquem o status do filme. 


MySOL Command Line Client 


sAluguel) FROM alugueis 


30 — Utilize a função DATEDIFF para saber qual a diferença 
entre duas datas. É uma forma de calcular eventuais multas 
por atraso. 
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Guia do CD 


ara visualizar o conteúdo, basta 
acessar a interface do CD que 
acompanha a revista. É muito sim- 
ples: insira-o na gaveta de seu CD- 
ROM e aguarde alguns instantes até 
a abertura completa da tela principal. Caso o 
recurso de auto-reprodução não esteja ativa- 
do, você pode abrir o CD clicando em Iniciar, 
Executar e digitando a letra correspondente 
ao seu drive de CD-ROM (DA ou EA, por 
exemplo). Escreva o comando BROWSER. 
EXE e pronto! A interface será exibida na tela 
e estará pronta para a navegação. 
Por questão de espaço, serão apresen- 
tados somente alguns programas nesta 
página. Para ver todo o conteúdo do CD, 


acesse a interface. APOSTILAS 


FERRAMENTAS 

Firebird PHP Generator 7.4 — Ferramenta que o ajuda a gerar scripts 
PHP para as tabelas selecionadas do banco de dados Firebird. 
FlySpeed SQL Query — Ferramenta gráfica, fácil de usar, que cria 
queries em diferentes servidores de bancos de dados. 

DBGen - O DBGen é um gerador de dados para testes desenvol- 
vido pelo Grupo de Base de Dados e Imagens do ICMC da USP. 
Ele permite a geração e análise de diversos tipos de informações 
utilizadas para carregar uma base de dados de teste. 


SERVIDORES 

Easy PHP — Monte seu servidor Web com um simples toque do 
mouse. Pacote com Apache, PHP e MySQL. 

ApacheZTriad — Pacote de servidor Web com banco de dados 
MySQL pré-configurado. Contém o PHP, Apache, MySQL, módulo 
Pyton, entre outros. 


MODELAGEM DE DADOS 

DBDesigner — Auxilia e cria modelo de banco de dados por meio 
do qual é possível ver falhas de determinado sistema. 
Embarcadero ER Studio - Uma das melhores e mais conhecidas 
ferramentas para modelagem de dados. 


GERENCIADORES 

Database Browser — O Database Browser é um programa que se 
conecta a bancos de dados, permitindo a visualização, alteração, 
execução de scripts etc. Possui suporte de conexão ao Microsoft 
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SERVIDORES DE DADOS 


SQL Server, Oracle e ODBC. 
Database Tour — Database Tour é uma ferramenta para banco de 
dados universal. 


APOSTILAS 

Apostila Completa de SQL — Conteúdo didático completo em níveis 
básico, intermediário e avançado. 

Comandos SQL — Principais comandos SQL mostrados de forma 
clara e direta para melhor entendimento. 

Introdução ao MySql — Introdução ao SQL e MySQL para iniciantes. 
PostgreSQL pratico — Apostila com mais de 150 páginas abordando 
tudo sobre Postgre. 


UML 

Metamill - Metamill é uma ferramenta profissional de UML CASE 
que suporta todos os tipos de diagrama UML. 

Schematic - Schematic é uma ferramenta de diagrama que per- 
mite combinar textos, imagens, formas e conectores para criar 
diagramas informativos. 

Pacestar UML Diagrammer - UML Diagrammer o ajuda a gerar 
variedades de diagramas de UML. 


E-BOOK 

Curso Prático de Criação de Sites — Livro exclusivo com tudo o que 
é preciso saber para montar um site, instalar seu próprio servidor 
e usar banco de dados MySQL. 


Aprenda se divertindo! 


Fazer as tarefas escolares não precisa mais ser chato e complicado. Com o pacote Office for Kids (OK), 
as crianças aprendem de forma lúdica e intuitiva a fazer textos, planilhas e apresentações escolares. 
Os programas possuem interface amigável que, somada aos mais de 800 cliparts e às atividades 

do pacote, oferecem uma completa central de aprendizado. 


ss penses: 
tao Ele pos Penço Poem tes tu 


qui 


Escreva trabalhos e treine 
gramática com o OK Letras. 


Com o OK Números, monte 
planilhas e organize seus dados 


Apresentações escolares ficarão completas 
e criativas com o OKMultimeios 


Acesse o endereço abaixo para adquirir o Office for Kids por um preço especial! 


www.ciadosoftware.com.br/ok 


com a linguagem 


crunção ne SITES 


Conteúdo didático completo 
em níveis básico, intermediário e avançado. 
Principais comandos SQL mostrados 
de forma clara e direta para melhor entendimento. 
Introdução ao SQL e MySQL 
para iniciantes. 
Conceitos de análise e SQL Server 
da Microsoft. 
Apostila com mais de 150 
páginas abordando tudo sobre Postgre. 
Utilização do MySQL no PHP. 
Apostila com abordagem extensa sobre 
análise de ponto de função. 
Definições da linguagem e alguns exemplos. 


Domine 
à Úngua SQL 


Coletânea completa de aplicativos para 
trabalhar de forma dinâmica e eficiente 


o = 


Auxilia e cria modelo de banco de 
dados por meio do qual é possível ver falhas de 
determinado sistema. 

Ferramenta para modelagem 
de dados completa. Gera scripts SQL para Oracle, 
SQL Server, MySQL e Firebird. 

Uma das melhores e mais 

conhecidas ferramentas para modelagem de dados. 

É uma ferramenta intuitiva 
de modelagem de dados, que pode ajudá-lo a 
modelar, criar e manter bases de dados. DeZign 
for Databases usa diagramas de entidade 
relacionamento (DER). 

Trata-se de uma alternativa 

de baixo custo, porém é uma ferramenta poderosa 
para modelagem e design de bancos de dados. 


Curta sua 
pipoca com MySQL 


Obtenha scripts SQL de forma rápida e 
fácil com diversas ferramentas gráficas 


que automatizam essas tarefas 


Livro em linguagem fácil que ensina a montar seu 
servidor, criar sites utilizando PHP, MySQL e muito mais 


Monte seu servidor Web com um simples 
toque do mouse. Pacote com Apache, PHP e MySQL. 
Pacote de servidor Web com banco 
de dados MySQL pré-configurado. Contém o PHP, 
Apache, MySQL, módulo Pyton, entre outros. 


Ferramenta profissional de UML CASE que 
suporta todos os tipos de diagrama UML. 

Ferramenta de diagrama que permite 
combinar textos, imagens, formas e conectores para 
criar diagramas informativos. 

Software completo e com várias opções que 
modela inúmeros tipos de diagramas, inclusive UML. 
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CONHEÇA O PODER DA SQL COM UM SISGEMA DE LOCADORA 
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ATENÇÃO: o conteúdo do CD é composto por programas freeware, shareware e versões para demonstração. Alguns programas necessitam de conexão à 
Internet para registro. Requisitos Mínimos: processador Pentium Illou superior, 128 MB de memória, 32 MB de memória de vídeo em resolução de 800x600 
pixels, placa de som, gravador de DVD, CD-ROM com velocidade 16X e modem de 56 Kbps. Esses requisitos são focados na interface do CD. As configurações R$ 12,90 
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podem variar de acordo com os programas instalados. O CD foi testado no sistema Windows XP. Podem ocorrer distorções em outras versões. 390€ 9"771517"439003 


